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(54) Abstract Title 

Method and apparatus for providing responses for requests of off-line clients 

(57) An apparatus for providing responses for requests of an off-line client 92, comprising: a local 
request-response storage 703 which stores a plurality of requests and a plurality of responses; network traffic 
redirector 701, for redirecting requests of the client to the client machine itself by modifying system 
configuration of the client machine when the client is off-line and for redirecting requests of the client to the 
network connection 814 by resuming the system configuration of the client machine when the client leaves the 
off-line state and enters an on-line state; and a local off-line server 702, for receiving a request of the client 
redirected to the client machine itself, generating a response based on the request, the plurality of requests 
and the plurality of responses stored in the request-response storage, and returning the response to the client. 
The responses may be server responses intercepted while the client is on-line. Alternatively the responses 
may be user-defined. 
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METHOD AND APPARATUS FOR PROVIDING RESPONSES 
POR REQUESTS OP OFF-LINE CLIENTS 

The present invention relates to a method and apparatus for 
providing responses for requests of a client, and particularly to a 
method and apparatus for providing responses for requests of a client ' 
which is in an off-line state. 

The nineties of 20th century features a tremendous social 
technology revolution which is prompted by the combination of data 
processing industry with consumer electronics industry. Like all other 
revolutions, it has a prominent effect on the technology development 
trend especially accelerating the development of those technologies 
which have already been there but fledging in many years. One main field 
among these technologies is the transmission of the Internet relevant 
documents, media and applications. The combination^ consumer 

llTTT indUStry With PrOCesSin * industry greatly prompts the 

demands of versatile communication transmission methods. As a 
loose-coupled computer network used to transmit science and government 
data, internet enters a strikingly developing era after over ten years' 
silent existence. With such development, business and consumers can 
access all the documents, media and programs directly. 

The internet is an open and worldwide biggest computer network 
which includes lots of connected subnets. It has been developed from the 
previous American ARPAnet. Now i t is ^ using TC£>/Ip J" 
communication protocol. TCP/IP is acronym of -Transfer Control 
Protocol/internet Protocol-, which is a software protocol developed by 
American Department of Defense for computer communication. The Internet 
sdel " a <WH*i«lly distributed remote computer network 

system which executes such networking protocols to allow users to share 
and interact information. Because of this kind of widely used 
information sharing, remote networks such as Internet have been fully 
developing into the "open- systems. Therefore, users can design their 
software applications without constraints to perform the specific 
operations or services. The detailed information about the Internet 
nodes, objects and links can be referred in the textbook "Mastering the 
internet-, authored by G. H. Cady etc.. and published by Sybex 
Corporation in Alameda, CA in 1996. 

WWW is the Internet multimedia information indexing and retrieving 

tra'sTctZ ClientS . USe HyPSrteXt Protocol-,™ to achicve the 

transaction processing with the Web Server. HTTP is a well known 



communication protocol. It allows users to use Hypertext Markup 

Language HTML, which is a standard web page description language , to 

access all kinds of files such as text, graphics, image, audio and video, 
etc. HTML provides a basic file format, and allows developers to specify 
the links with other servers and files. 

The client /server structure is very popular in WWW. In most cases, 
the Web client uses browser to send requests to the web server, explain, 
and display or play the hypertext information and all kinds of multimedia 
data formats returned from the Web server. 

In the real client/server network application, it is not possible 
that the client -end software keep online all the time, especially for 
those executed on mobile devices. Currently, the widely used mobile 
devices include the notebook PC such as IBM Think£a<t^nandheld PC such as 
3COM PalmPilot ana IBM Work Pad, or many other handheld devices embedded 
with network connection. Because of the mobility of such devices, it is 
inconvenient for them to connect to the net in most situations. 

When network connection is impossible, it is absolutely necessary 
for the client side software to keep working off-line, thus not only the 
handy features of mobile devices but the huge advantages of the Internet 
could be fully utilized as well . 

Currently, the client side software is unable to work normally when 
off-line unless it has been specifically designed. Actually, there have 
been many specific methods to address this problem. But these methods 
are either for specific application or for specific hardware. A common 
and simple method is greatly in need to keep client side software working 
normally even when it is off-line. 

The important difference between on-line and off-line states is 
that during the on-line state the client can get the response from the 
server if necessary. But in the latter case, the client is unable to 
communicate with the server. So in client /server architecture, client 
side software is usually unable to keep on working normally during 
off-line state. 

It is an object of the present invention to provide a technique 
which alleviates the above drawbacks. 
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According to the present invention we provide an apparatus for 
providing responses for requests of an off-line client, characterized by 
comprising: 

a request-response storage (703) . provided in a client machine 
which stores a plurality of requests and a plurality of responses .- 

a network flow redirector (701) , for redirecting requests of the 
client from a network connection to the client machine itself by 
modifying system configuration of the client machine when said client is 
in an off-line state, and for redirecting requests of the client from the 
client machine itself to the network connection by resuming the system 
configuration of the client machine when said client leaves the off-line 
state and enters an on-line state; and 

an off-line server (702), provided in the client machine, for 
receiving the requests of the client redirected by said network flow 
redirector (701) to the client machine itself, generating responses based 
on requests received, said plurality of requests and said plurality of 
responses stored in said request -response storage (703) , and returning 
generated responses to said client as responses of a server. 

Also according to the present invention we provide a method for 
providing responses for requests of an off-line client, characterized by 
comprising steps of: 

(a) providing a request -response storage in a client machine, which 
stores a plurality of requests and a plurality of responses; 

(b) redirecting requests of the client from a network 'connection to 
the client machine itself by modifying system configuration of the client 
machine when said client enters an off-line state,- and 

(c) while said client is in the off-line state, repeatedly 
performing in the client machine steps of: 

(cl) receiving a request redirected to the client machine itself, 
(C2) generating a response based on said request, said plurality of 
requests and said plurality of responses stored in said request -response 
storage, and 

(C3) return i*g said response to said client as a response of a 
3 5 server. 
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According to the method and device provided in this invention to 
make the client keep normally working while off-line, there is no need to 
modify the client software itself, just make some modification in the 



client machine's system configuration. Thus, the mobility of the client 
machine is enhanced greatly. The off-line state is no longer an obstacle 
to the server and the client. Especially for the client-end software of 
Personal Digital Assistant (PDA) which is very complex, the mobility of 
the PDA device could be enhanced greatly because of the removal of the 
necessity to modify the client software. Furthermore, the user interface 
keeps unchanged when both on-line and off-line, so there is no need to 
give additional training to the users. 

These and other features and advantages of this invention will 
become apparent from detailed description of the preferred embodiments in 
conjunction with attached drawings, which are: 

Figure 1 shows a data processing system which implements this 
invention; 

Figure 2 shows the high level framework of the components of the 
data processing system shown in Figure 1; 

Figure 3 shows a handheld data processing system which implements 
this invention; 

Figure 4 shows the client/server architecture of a preferred 
embodiment of this invention ; 

Figure 5 shows the client/server architecture of the preferred 
embodiment of this invention in more detailed framework; 

Figure 6 shows the computer network which exemplifies the preferred 
embodiment of this invention; 

Figure 7 shows the detailed framework of the apparatus, which 
offers responses to the off-line client, provided by this invention; 

Figure 8 shows the flowchart of the method, which is used by the 
off-line client, provides by this invention; 

Figure 9 shows the flowchart of the method, which is used by the 
client when it ends its off-line state and enters on-line state, provided 
by this invention; 



Figure 10 gives an example to show the relationship among the 
internal pages of an insurance company; 

Figure 11 gives an example to show that the browser could get 
appropriate responses when off-line,- 

Several specific details will be offered in the following 
description, xt is obviously not necessary for persons skilled in that 
art to implement this invention using these details. It other cases, the 
well-known components or circuits are presented merely in the form of 
framework to avoid unnecessary details. m most cases, the details like 
timing sequence are omitted if such details are not helpful to fully 
understand this invention and are common knowledge to persons skilled in 
tne art . 

Now refer to Figure l, it shows a data processing system 20 which 
implements this invention. This system includes processor 22, keyboard 
82 and display 96. Keyboard 62 is connected to processor 22 by cable 
Display 96 includes display screen 30. which can be implemented by CRT 
LCD or electroluminescent display, etc. The data processing system also 
includes a pointing device 84, which can be implemented by tracing ball 
joystick, touching board, touching screen or the mouse shown in the ' 
figure. This pointing device 84 can be used to move the arrow or cursor 
ZrTl d " P ' ay 8Creen 30 ' P — " can be connected to one or more 
peripheral devices, such as modem 92. CD-ROM 78. network adapter 90 and 
floppy drive 40. Each peripheral device can be embedded inside or 
outside processor 22. The output devices such as printer 100 could be 
connected to processor 22. 

It should be acknowledged by persons skilled in the art that 
display 96. keyboard 82 and pointing device 84 can all be implemented by 
several currently well-known components. 

Now refer to Figure 2. it shows the high level framework of the 
components of the data processing system shown in Figure 1. The data 
processing system 20 is mainly controlled by the instructions which are 
readable to the computer. These instructions could be in the form of 
software, regardless of where or how to store or access the software 

irworr"" ^ te eX6CUted ° n CP ° S ° t0 thS *** P-cessing system 



R om St T 9e d6ViCeS COnneCted to the astern bus 5 include RAM 56. 

ROM S8, nonvolatile memory 60 and the circuit used to store and access 



information. ROM is used to store data that couldn't be modified. On 
the contrary, data stored in RAM can be modified by CPU 50 or other 
hardware devices. Nonvolatile memory 60 has the ability to still keep 
data even when power is down. Nonvolatile memory includes ROM, EPROM, 
flash memory and battery backup CMOS RAM. As shown in Figure 2, this 
kind of battery backup CMOS RAM could be used to store system 
configuration information. 

The extension card or board is a circuit board containing chips and 
other electronic components. These components are connected to offer 
additional functions or resources for the computer. In general, the 
extension card could be used to contain storage, disk controller 66, 
video card, parallel and serial port, and embedded modem. For those lap 
computers, handheld computers or other portable computers, extension card 
is usually implemented as PC card, as the similar size as the credit card 
and inserted into the slot beside or in the back of* the computer. One 
example of this kind of slot is PCMCIA (personal computer memory card 
international association) slot, defining No. 1, 2, 3 card slot. Empty 
slot 68 could be used to contain all kinds of extension card or PCMCIA 
card. 

Both disk controller 66 and floppy controller 70 include specific 
integrated circuits and other related circuits. Xt is their 
responsibility to instruct and control reading and writing data from/to 
the hard disk drive 72 and floppy drive 74 respectively. The operations 
handled by this kind of disk controllers include locating read/write 
head, arbitrating between the driver and the CPU 50, controlling the 
transmission from/to the storage. A single disk controller can control 
more than one disk drives. 

CD-ROM controller 76 could be included in the data processing 
system 20, and read data from CD-ROM 78. This kind of CD-ROM uses laser 
components instead of magnetic equipment to read data. 

Keyboard-mouse controller 80 is used as interface between keyboard 
82 and pointing device 84 in data processing system 20. The pointing 
device is generally used to control an on-screen component. For example, 
an arrow- like cursor has a hot point which can specify the location of 
the pointing device when user clicks mouse or presses keyboard. There 
are many other pointing devices such as graphics input board, stylus, 
light pen, joystick, tracing ball, track board, and the devices with 
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Communication between the data processing system 20 and other data 
processing systems can be simplified by the serial port controller 88 
which is connected to system bus 5. and network adapter 90. The serial 
port controller 88 is used to transmit information between computers or 
5 between the computer and peripheral devices, one bit each time in a ' 

single line. Serial communication could be either synchronous 
(controlled by some standards such as clock) or asynchronous (managed by 
exchanging signals controlling information flow) . interface RS-232 and 
RS-422 are two examples of serial communication standard. As shown in 
10 the figure, this kind of serial interface could be used to communicate 

with modem 92. Modem is a communication device which enables computer to 
transmit information in the standard telephone line. Modem 92 converts 
the digital signal of computer to internal clock signal which is suitable 
for transmitting in telephone line, it can be used to connect the data 
processing system 20 with an online information service organization such 
as "PRODIGY" provided by IBM and Sears. This kind of online service 
provider can offer many software which can be downloaded to the data 
processing system 20 via modem 92. Modem 92 can provide connection to 
several software resources such as server, electronic bulletin board, the 
20 Internet and WWW. 

The network adapter 94 could be used to connect the data processing 
system 20 to LAN 94. LAN 94 can provide the device allowing users to 
man and transmit software and information electronically. Besides this 
it can also offer distributed processing, using several computers to 
share the workloads or cooperate while executing one task. 

The display 96 controlled by display controller 98 is used to 
display the video output generated by the data processing system 20 
This kind of video output includes text, graphics, motion picture and 
movie. The display 96 can be implemented by CRT based video display. LCD 
based plane display or gas plasma based plane display. The display 
controller 98 is an electronic component which can be used to generate 
the video signal transmitted to the display 96. 

The printer 100 could be connected to the data processing system 20 
via parallel port controller 102. it is used to place the text or image 
produced by the computer to paper or another media such as transparent 
film. There are several other types of printers such as image setter 
graph plotter, or slide recorder, etc. 



25 



30 



35 



8 



The parallel port controller 102 could be used to transmit multiple 
data bits and control bits in the line between system bus 5 and another 
parallel communication device such as printer 100. 

CPU 50 is charge of reading, decoding and executing instructions, 
and transmitting information from/ to other resources via system bus 5, 
which is the computer's main data transmitting route. This kind of bus 
connects all components in the data processing system 20, also specifying 
the media which is used to exchange data. As shown in Figure 2, system 
bus 5 connects storage 56, 58. 60, CPU 50 and other devices, and enables 
data exchange among them. 

Now refer to Figure 3, it shows a handheld data processing system 
300 which implements this invention. The front board of the system 
includes display screen 301, hand writing area 302, scrolling buttons 
303, application buttons 304. Display screen 301 is used to display the 
information stored in the handheld data processing system 300. It is 
touch sensitive, which means it can induce when user point-clicks the 
screen by a pen. It can also display the control and configuration 
information when application is executing. Hand writing area 302 is used 
by user to write text by the pen. Scrolling buttons 303 is used to help 
view the text or other information beyond the display screen 301, 
including up scrolling and down scrolling button. Application buttons 
304 is used to activate applications, each with a special icon. The 
handheld data processing system 300 could be WorkPad from IBM, or 
PalmPilot from 3COM. As for IBM's WorkPad, there are four application 
buttons in its front board, corresponding to notepad, address book, task 
list and memo respectively. In addition, an appropriate pen (not shown 
in the figure) could be provided together with the handheld data 
processing system 300 for the special purpose of point clicking display 
screen 300 or writing on hand writing area 302. 

The high level framework of the handheld data processing system 300 
is similar with that shown in Figure 2. The difference is that some 
components in Figure 2 are omitted to achieve the small and handy 
features. In general, the handheld data processing system 300 uses a 
storage module instead of huge capacity outer storage devices such as 
disk as memory. Currently, its total memory space is less than 1M. 
Although the PCMCIA card can be used to extend memory space, the memory 
capacity after extending is still no more than several megabytes. As for 
IBM WorkPad, memory space is divided into ROM and RAM, located in the 
same storage module. ROM has the capacity of 0 . 5M to 1.5M, RAM has the 
capacity of 1M at least. The main application group is preset into ROM. 



Other alternate applications and system extensions can be loaded into 
RAM. But it is not always feasible with regard to the limitation of the 
capacity of ram. users can upgrade or improve software by changing ROM 
or change the system software and application group completely by 
5 installing a single storage module. Furthermore, a typical handheld data 

processing system 300 usually embeds strong network communication 
ability, which means easy connection to the Internet or www. 

^ "f refer t0 Fi5Ure 4 ' At show * the client/server architecture of 
10 the preferred embodiment of this invention. As shown in this figure 

client request (such as the request for news) 91 is sent to server 88 by 
client 92. Server 88 could be a remote computer system accessible via 
the internet or other communication networks. Client 92 could execute on 
computer 20 shown in Figure 1. or the handheld computer 300 shown in 
15 Figure 3. 

When server 88 receives the client's request, it scans and searches 
the original (for example, uncompressed) information (such as online news 
or news group) . then offers the filtered electronic information as server 
response 93 to the client 92. 
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Client 92 could be executed on a first computer, server process 
could be executed on a second computer. They communicate to each other 
via communication media, thus providing the distribution ability and 
allowing multiple clients to access the same server at the same time. 

As for www. the browser process executed on the client machine is 
charge of establishing and maintaining connection to the server, and 
providing information to the user. The server machine executes the 
appropriate server software, which can provide information to the client 
m HTTP response. HTTP response is corresponding to the Web page written 
in HTML, or other data generated by server. 

" USed to define linkage when the HTML compatible browser 
executes on the client machine. The client machine requests the server 
marked by the linkage, and receives the files in HTML format from the 

server. 



N . yhS?" 5 ** CUr ^/ liable ^ the market, such as Netscape's 
Navigator .^Communicator, Microsoft's IE. Mosai^deU loped by NCSA 
Urbana -Champaign. Illinois, and Lynx browser, can be used in this' 
invention. Actually, any other browser which conforms to HTTP 
specification can be used too. 
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An Internet service is generally accessed via a unique network 

address uniform resource locator (URL) , which implies the network 

route to the server. URL has the special syntax for defining network 
connection. It is basically divided into two parts, one is protocol 
name, the other is the path name of the accessed object. For example, 
the URL -http://www.uspto.gov" (the home page of American patent and 
brand bureau) defines the transfer protocol °http" and the server path 
• www. uspto.gov" . The server name is corresponding to a unique IP address. 

Now refer to Figure 5, it shows the client /server architecture of 
the preferred embodiment of this invention in more detailed framework. 
As shown in this figure, client 92 connects to server 88 via network 
connection 814. Network connection 814 could be the Internet, intranet 
or other well-known interconnection. As for the Internet, server 88 is 
one of the many servers accessible to client 92. The label 92 represents 
a client which is a process executed on some client^machine, such as Web 
browser, mail reader, FTP client, Telnet client, etc. 

The client machine could be the desktop, notebook, handheld 
computer or palm computer. For example, ^the client machine could be an 
IBM or IBM compatible computer with OS/2, IBM ThinkPad, another x86 or 
pentium based computer with Windows^ 3.1 or higher ve^sicyi operating 
system. It could also be an IBM Work Pad with PalmOS, or some kind of PDA 
with strong network communication ability. ^ 

A typical server includes an IBM RISC/6000 with AIX operating 
system and server program. In this situation, the server usually 
receives requests from the client via dialling, then performs the 
appropriate tasks such as finding the specified files or objects to 
fulfil the client's requests. IBM has issued lots of publications to , 
present the different types of RISC based computers, such as "RS/6000. 
7013, 7016 POWERstation and POWERserver hardware technical reference 
manual" (SA23 -2644-00) . AIX is presented in detail in the first edition 
of "AIX operating system technical reference manual " and other 
publications. Although the structure mentioned above is feasible, it is 
not the only one, any other suitable hardware /operating system/server 
combination is also allowed. 



Now refer to Figure 6, it shows the computer network 80, which 
exemplifies the preferred embodiment of this invention. Computer network 
80 could be the Internet, or any other well-known computer network with 
client-server architecture. Persons skilled in the art should know that 
the Internet is not the only distributed computer network which 
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exemplifies the preferred embodiment of this invention. Computer network 
80 could certainly be implemented by other distributed computed networks 
such as "intranet". 

In theory, the Internet is a huge computer network which includes 
servers 88. The clients, usually the personal computer users, could 
access these servers via some special Internet access providers 84 such 
as internet America or online service providers such as America On-Line 
Prodigy. Compuserve etc. Each client machine can execute one or more 
browsers to access servers 88. Each server 88 is charge of so-called 
"web site" . 

It is helpful to have some knowledge of network and its operation 
principle because this invention involves much of network transmission. 
The details of these knowledge is omitted here. 

Now refer to Figure 7, it shows the detailed framework of the 
apparatus, which offers responses to the off-line client, provided by 

tw ' nV ! nti0n - Client 92 and — 88 «*°wn - this figure is same as 
that in Fl gure 4 and Figure 5. The network connection 814 is identical 
to the one shown in Figure 5. 

The most fundamental elements in Figure 7 are network traffic 
redirector 701. off-line server 702 and request -response storage 703. 
They construct the basic apparatus of this invention. Network traffic 
redirector 701 has the following role. When client 92 is in on-line 
state, for example, when it is using browser to browse the web pages of 
server 88, network traffic redirector 701 makes no change to the network 
transmission between client 92 and server 88 at all. i„ other word 
client 92 sends its requests to server 88 via network connection 814. 

then return: " " «~"*P°^ -sks and 

wtln It ? reSpOUSes to the <*"nt via network connection 814. 

When the client is in off-line state, i.e.. when the network connection 
814 is nonexistent or unable to achieve, network traffic redirector 701 
will redirect the requests of client 92 to off-li„e server 702 in local 
machine, then it is up to the off-line server 702 to respond 
corresponding (the detailed description will be given in the following, . 

The just mentioned functions of network traffic redirector 701 
could be implemented by modifying the system configuration of client 
machine. As mentioned above. ORI. is basically divided into two parts 
one is protocol name, the other is the path name of the accessed object 
For example, the URL "http://www.ibm.com" specifies the server path ' 
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"www. ibm.com" . The server path name is corresponding to a unique IP 
address. Actually, all data transmission on the Internet is performed by 
IP address. When a client specifies a server path name, a conversion 
mechanics is needed to do the conversion between server path name and IP 
address. Currently in the Internet, it is up to the domain name server 
to do this kind of conversion. So, what the network traffic redirector 
701 does is converting the server path name to the local IP address of 
client machine, or restoring the original IP address. 

Actually, the IP address conversion process can be performed by the 
following simple file operations. According to TCP/IP protocol, the 
operating system will search the "HOSTS" file in the local file system 
first when it gets a URL. For example, as for Windows NT, "HOSTS" file 
is stored under the directory "\NT\system32\drivers\etc\^; and for UNIX* 
this file is stored under the directory "/etc"; and for windows 95, the^ 
file is stored under the directory "\windows". A conversion list is 
contained in this file. Each conversion item occupies a single line. In 
each line, IP address is placed in the first column, and the server path 
name is in the second. 

The IP address and the host name should be separated by at least 
one space. The following is a sample hosts file that includes two 
records : 

102 .54.94.97 rhino . acme . com 

36.25.63 . 10 x. acme. com 

Since a domain server on the Internet can translate a host name to 
its IP address, the hosts file in a client machine is usually empty or do 
not exist. 

In this invention, the client machine's operating system will 
redirect requests that is sent to the host name to itself after several 
records are added in its hosts file. 

For example, suppose the IP address of the client machine is 
9.185.8.20. The following records are added to the hosts file on the 
client machine: 

9 . 185 .8.20 www. ibm. com 

9.185.8.20 www . uspto . gov 
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Requests that are sent to www.ibm.com or www.uspto.gov from the 
client machine will be redirected to itself. 

If the content of the hosts file on the client machine is cleared 
in order to recovery the system setting, requests that are sent to 
www.ibm.com or www.uspto.gov will be sent to their real IP address bv a 
domain server. 

When the client (92) is off-line, the network traffic redirector 
(701) can redirect requests to the off-line server (702) and send 

TZT" ^ ^ fr ° m ° ff_line SeiVer (702) to the cli *nt ( 92 > so 
ITe In!llne ent ^ """^ ^ " ^ like the Client (S>2 > 

The request-response storage (703) stores multiple requests and 
their corresponding responses. These request -response pairs may be 
defined by users or be recorded automatically by the following steps 
according to this invention. 

that th?" T ^ 1±ent (92> " ° n " line ' USe " SCt itS State to "~rd so 
that the network traffic redirector (701, always sends requests to the 

off-line server (702). Once the client ( 92 > sends a request, the 

™ TZ£°£ (702> iDterCePt reqUeSt ' then the server 

(702) sends this request to the server (88) through the network 

connection (814) and receives the response from the server (88) (See 

Figure 7 dot line,, then the off-line server (702) sends the response 

from the server (88, to the network traffic redirector (701, . At the 

same time, the off-line server (702) saves the intercepted 

request-response pairs to the request -response storage (703) in a 

specific data format. The data format has no restriction on this 

se^er 1 !70 21 ACtUally ^ ^ ^ if the "ff-lin. 

ItZllSl l 9Cnerate 3 reSP ° nSe acc - d -9 to a requests and multiple 

TZV \T r T° nSeS that a " in thC "^st-response storage 

i sends IT netW ° rk traffi ° redi " Ct0r < 701 > "ceives the response, 

it sends the response to the client (92). The process can be repeated 
until users complete recording. P 

The content of a request or a response is different from one 
network protocol to another, such as HTTP ( Hypertext Transfer Protocol) 
FTP (File Transfer Protocol, and Telnet. These are common sense for 
persons skilled in the art. The detail is not described. 
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When the client (92) is on-line, each request from the client (92) 
will be sent to the server (8B) by the network connection (814) and each 
response from the server (88) will be received by the network connection 
(814) . As mention above, when the client (92) is off-line or on record 
status, each request from the client (92) will be redirected to the 
off-line server (702) by the network traffic redirector (701) . Each 
response from the off-line server (702) will be sent to the network 
traffic redirector (701), then will be sent to the client (92). 

The above description is a method that is used to create multiple 
requests and responses stored in the request -response storage (703) : they 
are defined by users or intercepted by the off-line server (702) when 
users set the record status. Actually users can edit and modify 
appropriately the content of requests and responses and define default 
responses for some specific requests in order to simulate the real world. 
What is more, after the content of the request -response storage (703) is 
generated at a client machine, one can simply copy the content to the 
request -response storage of the other client machines in order to avoid 
defining, intercepting and editing. 

In addition, persons skilled in the art should understand that the 
storage described at this paper can be any standalone storage or part of 
storage at a client machine. For example, it can be a database or file 
on the disk (72) showed at the Figure 2. It also can be RAM (56) showed 
at the Figure 2. It can be a storage card at a palm computer showed at 
the Figure 3 . 

When the client (92) is off-line, the off-line server (702) begins 
to work. First of all, the off-line server (702) receives requests from 
the client machine itself redirected by the network traffic redirector 

(701) , then the off-line server generates a corresponding response to the 
request according to the request and multiple requests and responses 
stored in the request -response storage (703) . 

The following is a simple process that how the off-line server 

(702) generates a response according to a request and multiple requests 
and responses at the request -response storage (703) : 

Assume there are multiple requests and responses in the 
request -response storage (703) : 

Rl ( Request 1) 
Si ( Response 1) 
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R2 (Request 2) 
S2 ( Response 2) 



Rn ( Request n) 
Sn ( Response n) 

When the off-line server just receives a request R, it constructs a 
response according to the formula (i) s scructs a 

S = f (R. Rl, R2 to# S1# S2 Sn) _ 

as an example of U, , response S can be one of responses from si to 



Sn. 



S - SI, if R logically equals to Rl ; 

S2, if R logically equals to R2; 

(2) 

Sn, if r logically equals to Rn; 

With HTTP as an example, suppose the content of ri : 
GET URL1 

DATE 99.01.01 /HTTP 

and the content of R : 
GET URL1 

DATE 99.01.10 /HTTP 

Obviously, the content between Rl and R is different. But the 
essential part is the same: GET URi.1. that raeans requesting tne 

tTrfriL"^ ^ T 1 * theref ° re ^ ~ e -S* belhe samt so 
the off-lxne server (702) makes the decision that R logically equals to 
Rl and generates a response S that is the same as si Tt the 
request -response storage (703). 

Note that the above example is for explanation only. Actual 

ZTsZlT^Tl" differCnt ^ - ^ <^-nce 

aoes not limit this invention. 
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As a general case of formula (1), the Response S can be generated 
based on Request R, Request Rl to Rn and Response SI to Sn. For a simple 
example, assume the content Rl: 

http : //search . yahoo . com/bin/ search ?p=game 

and the content of R: 

http : //search . yahoo . com/bin/search?p» Internet 

Although Rl logically equals to R, the parameters in the URL are 
different- Therefore, Response SI do not become Response S. Then the 
content of Response S could be: 

"Sorry, there is no sufficient local data. Cannot search Internet- 

According to this invention, the off-line se rarer (702) can be 
programmed using complicated algorithms so that it can generate a 
appropriate response according to the received request and multiple 
requests and responses stored in the request -response storage (703) . 
These algorithms do not limit this invention. 

The basic devices in this invention include the network traffic 
redirector (701), the off-line server (702) and the request -response 
storage (703) . There are several devices that can be added to this 
invention: an off-line request storage (705) and an actual network 
service provider (706) . All of them are on the client machine. When the 
client (92) is off-line, upon the off-line server (702) receives a client 
request, it generates a response according to the received request and 
multiple requests and responses stored in the request -response storage 
(703) . It stores the request sequentially in the off-line request 
storage (705) . When the client (92) ends off-line state, the off-line 
request storage (705) has stored all requests from the client (92) when 
it was off-line. When the client (92) is on-line, the actual network 
service provider (706) starts to work. It fetches a request from the 
off-line request storage (705) one by one, then sends the request to the 
server (88) through the network connection (814) . The server (88) 
carries out the task required by the client (88) . 

To make even more attractive, the apparatus of this invention also 
includes an off-line response storage (704) , a comparison device (707) 
and a notification device (708). All of them are on the client machine. 
When the client (92) is off-line, the off-line server (702) sends a 
response to the network traffic redirector (701), then it stores this 
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response to the off-line response storage (704) sequentially. So 
responses stored in the off-line response storage (704) are correspond!™ 
to requests stored in the of f - line request storlge (70S, . of clursT 
persons filled in the art should understand that the off-line re^st 

iTallf 70S> ^ 0 " - llne reSP ° nSe St ° ra3e ' 704 > ~ ^ 

xnto different storage or located at the same storage only if it can 

2 s dlff COr ! e6P ° ndin9 " lati <™ hi P ^tween requests Ld respites 
This difference does not limit this invention, when the client ^2, ends 
off -lane, not only does the off-line request storage (70S, store all 
requests sent by the client (M) when it was off-lL. the offline" 
response storage (704) stores also all responses that the of f -li^server 
(702, sent to Client 92. when the client ( 92 , is on-line, the actual 
network service provider begins to work, xt fetches requests f rom th e 
of -line request storage (70S) sequentially, then sends^he request to 
the server (88, through the network connection (814 L . The server 88^ 

"r^nr the request from the ciient ^ »-». * - 

(82, receives the response from the server (88, through the network 
connection ( 81 4, and sends it to the comparison devic! (707, Z 

to it and is stored in the off-line response storage (704). if there is 
be sT'f d 6rr0r ^ C °^ ariSOn «- notification device (708^ wi 1 

to cat: lll iePOI l ^ err ° r ^ US6rS - ° nS ° f the elective methJs s 
iyoT ^ " S ° ftWare - The *<*ual ^twork service provider 

(706, repeats the above process until all requests stored in the off-line 
request storage (70S, have been processed. off-line 

An example that shows how the comparison device (707) works is 
IZ: 8 TH W ' " CM C ° mPare StatUS «~ ° f responses. S^pose 

IZlr Z Zt l: th V f f' line reqUSSt St °~* e (705) * « - the 
Response s! ' ""^ P ~ Vi *~ <™> receives 

-HTTP l.o 302 Object Not Found- 
ed Response SI which is stored in the off-line response storage (704, 
and corresponding to Request Rl is: 

"HTTP 1.0 200 OK" 

"l^l etro " %„ "°" "* ""^ " -~ «>« there 

ogic.1 error, m another word. Response S! sent to the client < S2 | 
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is wrong. So the comparison device (707) starts the notification device 
(708) to report this error to users. 

There are certainly other comparison methods that can be used by 
the actual apparatus. But these minor differences do not limit this 
invention. 

Figure 8 shows the basic flow chart when the client is off-line. 
After step 800, whether the client goes off-line will be decided at step 
801. If no, then it will turn to the flow chart showed in Figure 9. If 
yes, it will go to step 802. The client machine configuration will be 
modified at step 802 in order to make the network traffic to be routed 
back to the client machine itself. The method to modify the client 
machine configuration is showed in Figure 7. It can only modify the 
hosts file at the client machine. The .detail is not necessary to be 
repeated . ^ 

At step 803, a request from the client will be received, then it 
will be stored in the off-line request storage at step 804. A response 
will be generated according to the received request and multiple requests 
and responses stored in the request -response storage at step 805. The 
method to generate the response has been described above and showed in 
Figure 7. 

Then the response from step 805 will be sent to the client at step 
806 and stored in the off-line response storage at step 807. The 
off-line response storage is showed in Figure 7. 

Whether the client ends the off-line operation will be decided at 
step 808. If the result is false, then it will turn to step 803 and 
continue. Otherwise it will finish or turn to the flow chart showed at 
Figure 9 . 

Note that the execute sequence can be changed. For example, step 
804 can be executed after step 805 or after step 806 or after step 808. 
Step 604 is not necessary to be executed after step 803. Another example 
is that step 807 can be executed before step 806. These subtle 
differences do not limit this invention. In addition. If the content of 
the off-line response storage do not be used later, step 807 can be 
deleted. 

In addition, the off-line request storage and the off-line response 
storage can be separated to standalone storage or located at the same 
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storage only if it can maintain the corresponding relation between 
regue.t. ana reepons... mis difference doe . ^ ^ ^'^^ 

figure » enow, the flow chart .hen the client end. the off-lm. 
operation and goes on-line, whether the client go., on-linl !iu 11 
deexded at .tep 901. If the result i. false, then it win turn " , 
910 and .top. „ the result i. true, then it .ill turTt" %Z To, Z 
client machine-, configuration .ill be restored at step L • ' „ ! 
route the networ* traffic to the networ* connection inLad of 
machine itself . The method to modify the client m.chL s confi^rl " 
i. the same as step ao 2 . The detail i. no t neee.sary to be repeal 

will turn to step ,i„ and end. otherwise it will execute step ^ " 

iz::i s r the o,£ - un * ~ - — r - 

^ and the eeL.TwiU ^^1^ mTl^Si: V 

a " Tnen™ ~~ ' °~ ™ connection 

at step 906. Then the response will be compared with the one which 

corresponding to the request sent to the server (stored in the^ff IxL 
response storage at step 8 07 showed in Pigure 8, at step 307 ^heT 
the comparxson result has logical error will be decided at step ^a " 
meaning of logical error «-u~ ac SCe P 908 - The 

showed in Figure 7 T t " ° l ° ™«**^°" *vi« 

to the elienTat L " fal "' " ™™ T '*°°""> ■«* 

it will tum <:\z;: e ^izir^ir^zv"- oa - is - 
rrLueL zzr ~ ~ ^ ^ - 

- server ZlT^^^^X s'teptT ~ " 
^^^^ 

- .erver receive, the're^et^ ^V.^'.^"™- 
page to the browser. The browser receives this HT^f^e 

When the clerk clicks the first hot link (l SpIi t „ 
browser will get the URL of the first hot i*!v . ^^ance) , the 

cne txrst hot lxnk and generate another 
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request and send it to the server. The server will receive this request 
and generate a response according to the URL at the request and send back 
it to the browser. Then the browser will receives this response and 
display information. The clerk will see the "Selling Form" page 1001. 
There are three empty fields 1001A, 1001B and 1001C on the form 1001. 
When the clerk sells insurance, he will fill these three empty fields 
according to a customer information. Persons skilled in the art know 
that data filled at these three empty fields will become parameter stored 
at a URL. These three empty fields are an example. The number of empty 
fields relates to a customer information required by the sell insurance 
business. It does not limit this invention. 



There are two hot links in the page 1001: n OK n and "Cancel". If 
the clerk clicks the "OK" , the browser will send a requests which 
includes the above three parameters to the server. If the server handles 
this request correctly, it will send back another HXTP response and the 
browser display the "Selling OK" page 1003 correspondingly. If the clerk 
clicks the "Cancel" , the browser will display the "Selling Cancel" page 
1004 . 

Similarly, when the clerk clicks the second hot link (2. Claim) in 
the page 1000, the browser will display the "Claiming Form" page 1002 
from the server. There are three parameters in this page. When the 
clerk clicks "OK" in the page 1002 , the browser will send a URL request 
which includes three parameters to the server. If the server handles 
this request correctly, it will send back the "Claiming OK" page 1005. 
If the clerk clicks the "Cancel" in the page 1002, the browser will 
display the "Claiming Cancel" page 1006. 

Since the protocol in this example is HTTP, requests and response 
between the browser and the server accord to the HTTP format. 

Assume a clerk of the insurance company wants to visit three 
customers to sell insurance for two of customers and process claim for 
one of customers. There are several ways to process this business. The 
first one is that the clerk invites these three customers to his company 
and surfs his company's Intranet site and fills the above forms 1001 and 
1002 to process the business using the browser. Obviously it is 
unrealistic to invite customers to the company. The second one is that 
the clerk visits the above three customers outside taking a notepad 
computer or a palm computer which has installed a browser, when he 
visits each customer, he connects his notepad computer or a palm computer 
to his company's server by dial-up networking and gets the corresponding 
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forms and fills them and asks the server to process the insurance or 
claxm business. Since it is no guarantee to obtain network connection 
anywhere, the second method has shortcoming considering the low Internet 
transport speed and the security of network transport. 

Inconvenience can be overcome using this invention. For example 
before the clerk goes out to visit the above three customers, he connects 
his notepad computer or his palm computer to the company's server and 
sets the status to record. Then he surfs his company's Intranet site to 
go through the home page 1000, Selling Form 1001. Selling OK 1003 
Selling Cancel 1004. Claiming Form 1002. Claiming OK 1005 and Claiming 
Cancel 1006. After he ends surfing, the request-response storage 
installed at his notepad computer or his palm computer has stored all 
kinds of requests that need to be sent to the company's server when he 
goes out and corresponding responses. 

Of course, data stored at the request -response storage can be 
preset and edited by computer professionals of the insurance company 
Before each clerk goes out to do business, the preset data will be copied 
to the request-response storage at his notepad computer or the proper 
storage card will be installed to his palm computer. 

When the clerk goes out. he does not need to connect to the company 
server. He works off-line as if he did on-line. 



Figure n shows a browser gets responses when it is off-1 



ine . 



For example, when the clerk visits the first customer, he starts a 
browser to send a request. According to the method or the apparatus of 
this invention, that can generate a response according to the request 
sent by the browser and multiple requests and responses stored in the 
request-response storage, the browser gets the response and displays the 
home page lioo. since the clerk sells insurance to the first customer, 
he clicks -i. selling insurance-. The browser gets a response according 

stored "^r' ^ ^ br ° W8er *"* mUltiple re ^ ests * nd responses 

stored m the request -response storage and displays the Selling Form 

111*'* ^ Clerk fillS firSt CU8t ° mer ' 8 **. ^ these empty fields 

1101A. 1101B and 1101C and clicks -OK- . The browser gets the 

corresponding response and displays the Selling OK 1103. At last, the 

anl r the !^ S i the br ° WSer ' Pr ° CeSe ' **" ° ff - line "*" est 8t ~age 

and the off-line response storage installed at the clerk's notepad 

computer has stored multiple requests and responses. 
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Similarly, after the clerk visits the second customer, the off-line 
request storage and the off-line response storage has increased multiple 
requests and responses. 

When the clerk visits the third customer, he starts a browser. The 
browser displays the home page 1100. Since he wants to process claim, he 
clicks "2. Claim". The browser gets a response according to the request 
sent by the browser and multiple requests and responses stored in the 
request -response storage and displays the Claiming Form 1102. The clerk 
fills the customer's data and clicks "OK". The browser gets the 
corresponding response and displays the Claiming OK 1105. At last, the 
clerk closes the browser. In this process, the off-line request storage 
and the off-line response storage installed at the clerk's notepad 
computer has also increased multiple requests and responses. 

Therefore, the browser looks like on-line in the above process not 
only to the clerk but also to customers according to the method or the 
apparatus of this invention. 

When the clerk comes back to his office, he connect his notepad 
computer to the server within the Intranet. Multiple requests stored in 
the off-line request storage can be automatically sent to the server 
according to the method or the apparatus of this invention. The server 
handles the real tasks: two selling insurance and one claiming. Of 
course, there may be logical error that need be reported to users in this 
process as mentioned above. For example, when selling insurance, the 
customer filled his age to 90 and the browser displayed the page "Selling 
OK" . According to the policy of the insurance company, there is no 
insurance for a person whose age is 90 or larger than 90. Therefore, 
when the server handles this task, it sends the response "Sorry, the age . 
can not be over 90". So the logical error occurs. For example, the 
clerk is notified the logical error by the text "A customer's age can not 
be over 90" displayed in the browser window, then the clerk will verify 
this information to the customer or modify the customer's wrong data and 
send the request again. 

In addition, the method in this invention can be implemented to a 
computer application and stored in readable storage media in a computer. 
The application can be installed to mobile devices as a client software 
in a practical appliance. The client software does not need tp.be 
modified and can work off-line. The storage media can have versatile 
formats, for example the magnetic format or the optical format. 
Versatile formats don't limit this invention. 



Whale the preferred embodiments of the present invention have been 
described in detail with reference to the drawings, various amendments 
and changes can be made by persons skilled in the art. without departing 
the scope and the spirit of this invention. So the scope of this 
invention is limited only by the appended claims. 
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1. An apparatus for providing responses for requests of an off-line 
client, characterized by comprising: 

a request -response storage (703), provided in a client machine, 
which stores a plurality of requests and a plurality of responses ; 

a network traffic redirector (701), for redirecting requests of the 
client from a network connection to the client machine itself by 
modifying system configuration of the client machine when said client is 
in an off-line state, and for redirecting requests of the client from the 
client machine itself to the network connection by resuming the system 
configuration of the client machine when said client leaves the off-line 
state and enters an on-line state; and 

an off-line server (702), provided in the client machine, for 
receiving the requests of the client redirected by said network traffic 
redirector (701) to the client machine itself, generating responses 
based on requests received, said plurality of requests and said plurality 
of responses stored in said request -response storage (703), and returning 
generated responses to said client as responses of a server. 

2. The apparatus according to claim 1, wherein said plurality of 
requests and said plurality of responses stored in said request -response 
storage are a plurality of requests of the client and a plurality of 
responses of the server which are intercepted in the client machine while 
said client is in an on-line state. 

3. The apparatus according to claim 1, wherein said plurality of 
requests and said plurality of responses stored in said request -response 
storage are a plurality of requests and a plurality of responses which 
are pre-defined by a user. 

4. The apparatus according to any one of claims 1 to 3, wherein said 
off-line server comprises an off-line request storage (70S), for storing 
each request of the client received by said off-line server; and 

said apparatus further comprises: 

an actual network service means (706) , provided in said client 
machine, for sending each request stored in said off-line request storage 
(705) to the server through a network connection after said client leaves 
the off-line state and enters an on-line state. 

5. The apparatus according to claim 4, wherein said off-line server 
further comprises an off-line response storage (704), for storing the 
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responses returned to said client in an association manner with the 
requests stored in said off-line request storage; and 

said actual network service means, after sending each request to 
said server, further receives each response returned from sailer 

saxd apparatus further comprises: 

said VT^ 011 meanS (7 ° 7) ' f ° r com P ar ing said response received by 

in lid " rrr rk service means from said ^ * 

" ! ° ff ; line reSp ° nSe sto "* e *» *" association manner with the 
request sent to said server; and 

a notifying means (708) . when the comparison result of said 
comparison means indicates a logic error, for notifying the user of said 

client TclTi Pr ° Viding reS ^ ses '<* «q»--t. of an off-line 
cxient, comprising steps of- 

— =™ ; 

(t>> redirecting requests of the clW ^ 
the rUpnf n,, u- . client from a network connection to 

(=3) returning said response to said client as a response o f . 



server 
7. 



an, salTp^'TrisL" ^ ^ rei " ° f 
reoe.t.d,„ ! . , r«P«»»«s xn s.io step (a) are obtained by 
repeatedly per t o„*i„g blowing st . ps while ^ ^ ^ ^ J ^ ^ 

intercepting a request sent by said client to a server- 

r.^ivTnr.' 5 C ° thtOU9h * section, 

receding a response returned by said server- 
returning said response to said client; and 

storage" 0 "*" ~" ~" — reque.t-response 

user. " 1Urallty ° f "»P<»>»« i" said step (a) are pre-defined by a 
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9. The method according to any one of claims 6 to 8, wherein in said 
step (cl) the request received is further recorded in an off-line request 
storage provided in the client machine, and 

said method further comprises steps of: 

(d) redirecting requests of the client from the client machine 
itself to a network connection by resuming the system configuration of 
the client machine when said client leaves the off-line state and enters 
an on-line state; and 

(e) repeatedly performing following steps in the client machine: 
(el) retrieving a request from said off-line request storage; and 
(e2) sending said request to a server through a network connection. 

10. The method according to claim 9, wherein in step (c3) the response 
returned to said client is further recorded in an off-line response 
storage provided in the client machine in an association manner with the 
requests recorded in step (cl) , and 

said step (e) further comprises steps of : 

(e3) receiving a response returned by said server; 

(e4) retrieving from said off-line response storage a response 
associated with said request retrieved in step (el) ; 

(e5) comparing the response received in step (e3) with the response 
retrieved in step (e4) ; and 

(e6) notifying the user of an error if comparison result indicates 
a logical error. 

11. A computer- readable media for recording programs, on which a 
program is recorded for performing the method of any claim 6 to 10: 
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